<template>
  <xtx-dialog :title="(formData.id?'编辑':'添加')+'收货地址'" v-model:visible="dialogVisible">
    <div class="address-edit">
      <div class="xtx-form">
        <div class="xtx-form-item">
          <div class="label">收货人: </div>
          <div class="field">
            <input v-model="formData.receiver" class="input" placeholder="请输入收货人" />
          </div>
        </div>
        <div class="xtx-form-item">
          <div class="label">手机号: </div>
          <div class="field">
            <input v-model="formData.contact" class="input" placeholder="请输入手机号" />
          </div>
        </div>
        <div class="xtx-form-item">
          <div class="label">地区: </div>
          <div class="field">
            <xtx-city :fullLocation="formData.fullLocation" @change-city="changeCty" placeholder="请选择所在地区" />
          </div>
        </div>
        <div class="xtx-form-item">
          <div class="label">详细地址: </div>
          <div class="field">
            <input v-model="formData.address" class="input" placeholder="请输入详细地址" />
          </div>
        </div>
        <div class="xtx-form-item">
          <div class="label">邮政编码: </div>
          <div class="field">
            <input v-model="formData.postalCode" class="input" placeholder="请输入邮政编码" />
          </div>
        </div>
        <div class="xtx-form-item">
          <div class="label">地址标签: </div>
          <div class="field">
            <input v-model="formData.addressTags" class="input" placeholder="请输入地址标签, 逗号隔开" />
          </div>
        </div>
      </div>
    </div>
    <template v-slot:footer>
      <xtx-button @click="dialogVisible=false" type="gray" style="margin-right: 20px">取消</xtx-button>
      <xtx-button @click="submit()" type="primary">确认</xtx-button>
    </template>
  </xtx-dialog>
</template>

<script>
import { addAddress, editAddress } from '@/api/order'
import Message from '@/components/library/Message'
import { reactive, ref } from 'vue'
export default {
  name: 'AddressEdit',
  setup (_, { emit }) {
    const dialogVisible = ref(false)
    // // 打开函数
    // const open = () => {
    //   dialogVisible.value = true
    // }

    // 表单数据
    const formData = reactive({
      id: '',
      receiver: '',
      contact: '',
      provinceCode: '',
      cityCode: '',
      countryCode: '',
      address: '',
      postalCode: '',
      addressTags: '',
      isDefault: 1,
      fullLocation: ''
    })

    // 选择地区
    const changeCty = data => {
      formData.provinceCode = data.provinceCode
      formData.cityCode = data.cityCode
      formData.countryCode = data.countryCode
      formData.fullLocation = data.fullLocation
    }

    // 提交操作
    const submit = () => {
      if (formData.id) {
        editAddress(formData).then(data => {
          // 修改地址
          Message({ text: '修改收货地址成功', type: 'success' })
          dialogVisible.value = false
          emit('on-success', formData)
        })
      } else {
        addAddress(formData).then(data => {
        // 添加成功
          Message({ text: '添加收货地址成功', type: 'success' })
          formData.id = data.result.id
          dialogVisible.value = false
          emit('on-success', formData)
        })
      }
    }

    // 打开函数
    const open = form => {
      dialogVisible.value = true
      // 先填充数据-编辑
      if (form.id) {
        for (const key in formData) {
          formData[key] = form[key]
        }
      } else {
        // 先清空数据-添加
        for (const key in formData) {
          if (key !== 'isDefault') {
            formData[key] = ''
          }
        }
      }
    }
    return { dialogVisible, open, formData, changeCty, submit }
  }
}
</script>

<style scoped lang="less">
.xtx-dialog {
  :deep(.wrapper){
    width: 780px;
    .body {
      font-size: 14px;
    }
  }
}
.xtx-form {
  padding: 0;
  input {
    outline: none;
    &::placeholder {
      color: #ccc;
    }
  }
}
.xtx-city {
  width: 320px;
  :deep(.select) {
    height: 50px;
    line-height: 48px;
    display: flex;
    padding: 0 10px;
    justify-content: space-between;
    .placeholder {
      color: #ccc;
    }
    i {
      color: #ccc;
      font-size: 18px;
    }
    .value {
      font-size: 14px;
    }
  }
  :deep(.option) {
    top: 49px;
  }
}
</style>
